home *** CD-ROM | disk | FTP | other *** search
/ Computer Inter@ctive 17 / Computer Interactive cdrom 17 - gen 99.iso / ZDNETIT / CONTENT / OPTIVDOS.ZIP / INCLUDE.ZIP / VIMATH.H < prev    next >
Encoding:
C/C++ Source or Header  |  1998-10-21  |  3.1 KB  |  83 lines

  1. /*  VImath.h
  2.  
  3.   vector management functions for data type "int":
  4.   integer arithmetics and mathematics.
  5.  
  6.   Copyright (c) 1996-1998 by Martin Sander
  7.   All Rights Reserved.
  8. */
  9.  
  10. #ifndef __VIMATH_H
  11. #define __VIMATH_H
  12.  
  13. #if !defined( __VECLIB_H )
  14.    #include <VecLib.h>
  15. #endif
  16.  
  17. #ifdef __cplusplus
  18.    extern "C" {
  19. #endif
  20.  
  21. /******************   Basic  Arithmetics   *************************/
  22.  
  23. void  __vf  VI_neg( iVector Y, iVector X, ui size );
  24. void  __vf  VI_abs( iVector Y, iVector X, ui size );
  25.  
  26. void  __vf  VIo_addC(  iVector Y, iVector X, ui size, int C );
  27. void  __vf  VIo_subC(  iVector Y, iVector X, ui size, int C );
  28. void  __vf  VIo_subrC( iVector Y, iVector X, ui size, int C );
  29. void  __vf  VIo_mulC(  iVector Y, iVector X, ui size, int C );
  30. #ifdef V_trapIntError
  31.     #define VI_addC     VIo_addC
  32.     #define VI_subC     VIo_subC
  33.     #define VI_subrC    VIo_subrC
  34.     #define VI_mulC     VIo_mulC
  35. #else
  36.     void  __vf  VI_addC(  iVector Y, iVector X, ui size, int C );
  37.     void  __vf  VI_subC(  iVector Y, iVector X, ui size, int C );
  38.     void  __vf  VI_subrC( iVector Y, iVector X, ui size, int C );
  39.     void  __vf  VI_mulC(  iVector Y, iVector X, ui size, int C );
  40. #endif
  41. void  __vf  VI_divC(  iVector Y, iVector X, ui size, int C );
  42. void  __vf  VI_divrC( iVector Y, iVector X, ui size, int C );
  43. void  __vf  VI_modC(  iVector Y, iVector X, ui size, int C );
  44. void  __vf  VI_maxC(  iVector Y, iVector X, ui size, int C );
  45. void  __vf  VI_minC(  iVector Y, iVector X, ui size, int C );
  46.  
  47. void    __vf  VIo_addV(  iVector Z, iVector X, iVector Y, ui size );
  48. void    __vf  VIo_subV(  iVector Z, iVector X, iVector Y, ui size );
  49. void    __vf  VIo_subrV( iVector Z, iVector X, iVector Y, ui size );
  50. void    __vf  VIo_mulV(  iVector Z, iVector X, iVector Y, ui size );
  51. #ifdef V_trapIntError
  52.     #define VI_addV    VIo_addV
  53.     #define VI_subV    VIo_subV
  54.     #define VI_subrV   VIo_subrV
  55.     #define VI_mulV    VIo_mulV
  56. #else
  57.     void    __vf  VI_addV(  iVector Z, iVector X, iVector Y, ui size );
  58.     void    __vf  VI_subV(  iVector Z, iVector X, iVector Y, ui size );
  59.     void    __vf  VI_subrV( iVector Z, iVector X, iVector Y, ui size );
  60.     void    __vf  VI_mulV(  iVector Z, iVector X, iVector Y, ui size );
  61. #endif
  62. void    __vf  VI_divV(  iVector Z, iVector X, iVector Y, ui size );
  63. void    __vf  VI_divrV( iVector Z, iVector X, iVector Y, ui size );
  64. void    __vf  VI_modV(  iVector Z, iVector X, iVector Y, ui size );
  65. void    __vf  VI_maxV(  iVector Z, iVector X, iVector Y, ui size );
  66. void    __vf  VI_minV(  iVector Z, iVector X, iVector Y, ui size );
  67.  
  68.  
  69. /*****************   Bit-wise operations  *********************/
  70.  
  71. void    __vf  VI_shl( iVector Y, iVector X, ui size, unsigned C );
  72. void    __vf  VI_shr( iVector Y, iVector X, ui size, unsigned C );
  73.  
  74. void    __vf  VI_and( iVector Y, iVector X, ui size, int C );
  75. void    __vf  VI_or(  iVector Y, iVector X, ui size, int C );
  76. void    __vf  VI_xor( iVector Y, iVector X, ui size, int C );
  77. void    __vf  VI_not( iVector Y, iVector X, ui size );
  78.  
  79. #ifdef __cplusplus
  80. }
  81. #endif
  82.  
  83. #endif   /*  __VIMATH_H    */